package com.module.weixin.order;

import java.util.HashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import com.module.weixin.util.MD5;
import org.apache.http.NameValuePair;
import org.apache.http.message.BasicNameValuePair;

import android.util.Log;

/**
 * <strong>统一下单</strong><br>
 * <br>
 *
 * 公众账号ID appid 是 String(32) wx8888888888888888 微信分配的公众账号ID <br>
 * <br>
 *
 * 商户号 mch_id 是 String(32) 1900000109 微信支付分配的商户号 <br>
 * <br>
 *
 * 设备号 device_info 否 String(32) 013467007045764
 * 终端设备号(门店号或收银设备ID)，注意：PC网页或公众号内支付请传"WEB" <br>
 * <br>
 *
 * 随机字符串 nonce_str 是 String(32) 5K8264ILTKCH16CQ2502SI8ZNMTM67VS
 * 随机字符串，不长于32位。推荐随机数生成算法 <br>
 * <br>
 *
 * 签名 sign 是 String(32) C380BEC2BFD727A4B6845133519F3AD6 签名，详见签名生成算法 <br>
 * <br>
 *
 * 商品描述 body 是 String(32) Ipad mini 16G 白色 商品或支付单简要描述 <br>
 * <br>
 *
 * 商品详情 detail 否 String(8192) Ipad mini 16G 白色 商品名称明细列表 <br>
 * <br>
 *
 * 附加数据 attach 否 String(127) 说明 附加数据，在查询API和支付通知中原样返回，该字段主要用于商户携带订单的自定义数据 <br>
 * <br>
 *
 * 商户订单号 out_trade_no 是 String(32) 1217752501201407033233368018
 * 商户系统内部的订单号,32个字符内、可包含字母, 其他说明见商户订单号 <br>
 * <br>
 *
 * 货币类型 fee_type 否 String(16) CNY 符合ISO 4217标准的三位字母代码，默认人民币：CNY，其他值列表详见货币类型 <br>
 * <br>
 *
 * 总金额 total_fee 是 Int 888 订单总金额，只能为整数，详见支付金额 <br>
 * <br>
 *
 * 终端IP spbill_create_ip 是 String(16) 8.8.8.8
 * APP和网页支付提交用户端ip，Native支付填调用微信支付API的机器IP。 <br>
 * <br>
 *
 * 交易起始时间 time_start 否 String(14) 20091225091010
 * 订单生成时间，格式为yyyyMMddHHmmss，如2009年12月25日9点10分10秒表示为20091225091010。其他详见时间规则 <br>
 * <br>
 *
 * 交易结束时间 time_expire 否 String(14) 20091227091010
 * 订单失效时间，格式为yyyyMMddHHmmss，如2009年12月27日9点10分10秒表示为20091227091010。其他详见时间规则 <br>
 * <br>
 *
 * 商品标记 goods_tag 否 String(32) WXG 商品标记，代金券或立减优惠功能的参数，说明详见代金券或立减优惠 <br>
 * <br>
 *
 * 通知地址 notify_url 是 String(256) http://www.baidu.com/ 接收微信支付异步通知回调地址 <br>
 * <br>
 *
 * 交易类型 trade_type 是 String(16) JSAPI 取值如下：JSAPI，NATIVE，APP，WAP,详细说明见参数规定 <br>
 * <br>
 *
 * 商品ID product_id 否 String(32) 12235413214070356458058
 * trade_type=NATIVE，此参数必传。此id为二维码中包含的商品ID，商户自行定义。 <br>
 * <br>
 *
 * 用户标识 openid 否 String(128) oUpF8uMuAJO_M2pxb1Q9zNjWeS6o
 * trade_type=JSAPI，此参数必传，用户在商户appid下的唯一标识。下单前需要调用【网页授权获取用户信息】接口获取到用户的Openid <br>
 * <br>
 *
 * URL链接 long_url 是 String(512)
 * weixin://wxpay/bizpayurl?sign=XXXXX&appid=XXXXX&mch_id
 * =XXXXX&product_id=XXXXXX&time_stamp=XXXXXX&nonce_str=XXXXX
 * 需要转换的URL，签名用原串，传输需URL encode <br>
 * <br>
 *
 * @author 朱朝旭
 */
public class AddOrder extends Order {

	private static final long serialVersionUID = 1L;

	/**
	 * 公众账号ID appid 是 String(32) wx8888888888888888 微信分配的公众账号ID
	 */
	public static String APPID = "appid";

	/**
	 * 商户号 mch_id 是 String(32) 1900000109 微信支付分配的商户号
	 */
	public static String MCH_ID = "mch_id";

	/**
	 * 设备号 device_info 否 String(32) 013467007045764
	 * 终端设备号(门店号或收银设备ID)，注意：PC网页或公众号内支付请传"WEB"
	 */
	public static String DEVICE_INFO = "device_info";

	/**
	 * 随机字符串 nonce_str 是 String(32) 5K8264ILTKCH16CQ2502SI8ZNMTM67VS
	 * 随机字符串，不长于32位。推荐随机数生成算法
	 */
	public static String NONCE_STR = "nonce_str";

	/**
	 * 签名 sign 是 String(32) C380BEC2BFD727A4B6845133519F3AD6 签名，详见签名生成算法
	 */
	public static String SIGN = "sign";

	/**
	 * 品描述 body 是 String(32) Ipad mini 16G 白色 商品或支付单简要描述
	 */
	public static String BODY = "body";

	/**
	 * 商品详情 detail 否 String(8192) Ipad mini 16G 白色 商品名称明细列表
	 */
	public static String DETAIL = "detail";

	/**
	 * 附加数据 attach 否 String(127) 说明 附加数据，在查询API和支付通知中原样返回，该字段主要用于商户携带订单的自定义数据
	 */
	public static String ATTACH = "attach";

	/**
	 * 商户订单号 out_trade_no 是 String(32) 1217752501201407033233368018
	 * 商户系统内部的订单号,32个字符内、可包含字母, 其他说明见商户订单号
	 */
	public static String OUT_TRADE_NO = "out_trade_no";

	/**
	 * 货币类型 fee_type 否 String(16) CNY 符合ISO 4217标准的三位字母代码，默认人民币：CNY，其他值列表详见货币类型
	 */
	public static String FEE_TYPE = "fee_type";

	/**
	 * 总金额 total_fee 是 Int 888 订单总金额，只能为整数，详见支付金额
	 */
	public static String TOTAL_FEE = "total_fee";

	/**
	 * 终端IP spbill_create_ip 是 String(16) 8.8.8.8
	 * APP和网页支付提交用户端ip，Native支付填调用微信支付API的机器IP。
	 */
	public static String SPBILL_CREATE_IP = "spbill_create_ip";

	/**
	 * 交易起始时间 time_start 否 String(14) 20091225091010
	 * 订单生成时间，格式为yyyyMMddHHmmss，如2009年12月25日9点10分10秒表示为20091225091010。其他详见时间规则
	 */
	public static String TIME_START = "time_start";

	/**
	 * 交易结束时间 time_expire 否 String(14) 20091227091010
	 * 订单失效时间，格式为yyyyMMddHHmmss，如2009年12月27日9点10分10秒表示为20091227091010。其他详见时间规则
	 */
	public static String TIME_EXPIRE = "time_expire";

	/**
	 * 商品标记 goods_tag 否 String(32) WXG 商品标记，代金券或立减优惠功能的参数，说明详见代金券或立减优惠
	 */
	public static String GOODS_TAG = "goods_tag";

	/**
	 * 通知地址 notify_url 是 String(256) http://www.baidu.com/ 接收微信支付异步通知回调地址
	 */
	public static String NOTIFY_URL = "notify_url";

	/**
	 * 交易类型 trade_type 是 String(16) JSAPI 取值如下：JSAPI，NATIVE，APP，WAP,详细说明见参数规定
	 */
	public static String TRADE_TYPE = "trade_type";

	/**
	 * 商品ID product_id 否 String(32) 12235413214070356458058
	 * trade_type=NATIVE，此参数必传。此id为二维码中包含的商品ID，商户自行定义。
	 */
	public static String PRODUCT_ID = "product_id";

	/**
	 * 用户标识 openid 否 String(128) oUpF8uMuAJO_M2pxb1Q9zNjWeS6o
	 * trade_type=JSAPI，此参数必传，用户在商户appid下的唯一标识。下单前需要调用【网页授权获取用户信息】接口获取到用户的Openid
	 */
	public static String OPENID = "openid";

	/**
	 * URL链接 long_url 是 String(512)
	 * weixin://wxpay/bizpayurl?sign=XXXXX&appid=XXXXX&mch_id
	 * =XXXXX&product_id=XXXXXX&time_stamp=XXXXXX&nonce_str=XXXXX
	 * 需要转换的URL，签名用原串，传输需URL encode
	 */
	public static String LONG_URL = "long_url";

}
